<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div {
            width: 100px;
            height: 100px;
            background-color: pink;
        }
    </style>
</head>

<body>
    <div></div>

    <script>
        // 1. 选择节点
        let div = document.querySelector('div');
        // 3. 申明手指的初试坐标的的变量startX, startY
        // 4. 申明盒子原来的位置的变量x, y
        let startX, startY, x, y = 0;
        // 2. 触摸元素
        div.addEventListener('touchstart', function (e) {
            // 5. 获得手指的初试坐标
            startX = e.targetTouches[0].pageX;
            startY = e.targetTouches[0].pageY;
            // 6. 获得盒子原来的位置
            x = this.offsetLeft;
            y = this.offsetTop;

        });

        // 7. 移动手指事件
        div.addEventListener('touchmove', function (e) {
            // 8. 计算手指的移动距离： 手指移动之后的坐标减去手指初始的坐标
            var moveX = e.targetTouches[0].pageX - startX;
            var moveY = e.targetTouches[0].pageY - startY;
            // 9、移动我们的盒子 盒子原来的位置 + 手指移动的距离
            this.style.left = x + moveX + 'px';
            this.style.top = y + moveY + 'px';
            e.preventDefault(); // 10、阻止屏幕滚动的默认行为
        });
    </script>
</body>

</html>